<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryRef" :inline="true">
      <el-form-item label="用户账号" prop="userName">
        <el-input
          v-model="queryParams.userName"
          placeholder="请输入用户账号"
          clearable
          @keyup.enter="handleQuery"
        />
      </el-form-item>
      <el-form-item label="登录ip" prop="ipaddr">
        <el-input
          v-model="queryParams.ipaddr"
          placeholder="请输入登录ip"
          clearable
          @keyup.enter="handleQuery"
        />
      </el-form-item>
      <el-form-item>
        <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
        <el-button icon="Refresh" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>
    <el-table v-loading="loading" :data="onlineList" height="800">
      <el-table-column label="序号" width="50" type="index" align="center" />
      <el-table-column
        label="会话编号"
        align="center"
        prop="tokenId"
        :show-overflow-tooltip="true"
      />
      <el-table-column
        label="用户账号"
        align="center"
        prop="userName"
        :show-overflow-tooltip="true"
      />
      <el-table-column
        label="所属部门"
        align="center"
        prop="deptName"
        :show-overflow-tooltip="true"
      />
      <el-table-column label="登录ip" align="center" prop="ipaddr" :show-overflow-tooltip="true" />
      <el-table-column
        label="登录地点"
        align="center"
        prop="loginLocation"
        :show-overflow-tooltip="true"
      />
      <el-table-column label="操作系统" align="center" prop="os" :show-overflow-tooltip="true" />
      <el-table-column label="浏览器" align="center" prop="browser" :show-overflow-tooltip="true" />
      <el-table-column label="登录时间" align="center" prop="loginTime" width="180" />
      <el-table-column label="操作" align="center">
        <template #default="scope">
          <el-button
            link
            type="primary"
            icon="Delete"
            @click="handleForceLogout(scope.row)"
            v-hasPermi="['web:monitor:app:online:forceLogout']"
          >
            强退
          </el-button>
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>

<script setup>
  import { ref } from 'vue';
  import { forceLogout, list as initData } from '@/api/monitor/online';
  import modal from '@/plugins/modal';

  const queryParams = ref({
    ipaddr: null,
    userName: null,
  });
  const queryRef = ref(null);
  const onlineList = ref([]);
  const loading = ref(false);

  function getList() {
    loading.value = true;
    initData(queryParams.value)
      .then((res) => {
        onlineList.value = res.data;
      })
      .finally(() => {
        loading.value = false;
      });
  }

  function handleQuery() {
    getList();
  }

  function resetQuery() {
    queryRef.value?.resetFields();
    handleQuery();
  }

  function handleForceLogout(row) {
    modal
      .confirm('是否确认强退名称为"' + row.userName + '"的用户?')
      .then(function () {
        return forceLogout(row.tokenId);
      })
      .then(() => {
        getList();
        modal.msgSuccess('删除成功');
      })
      .catch(() => {});
  }

  getList();
</script>
